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(54) Tide: RETAIL SHELF INVENTORY SYSTEM 



(57) Abstract 

A retail shelf inventory management system includes memory 
for storing inventory data. The inventory data includes a study period 
and a retail opening time and a retail closing time for each day within 
the study period and historical inventory data for the study period for 
each of a number of different inventory items or products. The histori- 
cal inventory data includes a movement value, a customer service le- 
vel, a proportion of business done for each day within the study peri- 
od, and a variability of demand. An optimizing program and process- 
ing unit are operatively connected to the memory devices for optimiz- 
ing a shelf capacity (204) for any or each of said plurality of inventory 
items. Both user selected shelf capacity values and the optimized shelf 
capacity value can be separately utilized for calculating target stock le- 
vels (205), order-to-levels, estimated sales estimated lost sales (208), 
average inventory values (210) and customer service levels achieved. 
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RETAIL SHELF INVENTORY SYSTEM 
BACKGROUND OF THE TNVEtyTTOjs 

Field of the Inven^nn . : 

The present invention relates generally to inven- 
tory management systems and more particularly to data pro- 
5 cessing methodology and system for retail Shelf inventory 
management, t . - • v - 

Description of thg Prior Art 

Computerized inventory management systems aire 
known. A publication entitled "INFOREM Principles of In- 

10 ventory Management Application Description," second edition 
May, 1978 copyright IBM Corporation, provides a description 
of general principles of inventory mdn&gement and how these 
principles are implemented in the INFOREM application pro- 
gram for inventory management developed by IBM Corporation, 

15 However, such computerized inventory systems. have not ade- 
quately addressed the problem of providing" a retdil shelf 
inventory management system having data* processing method- 
ology capable of identifying an optimum shelf capacity on 
an individual product basis and utilizing the identified 

20 optimum shelf capacity for generating reordering time 
schedules and quantities for individual products . 
Summary of the Invention 

A principal object of the present invention is to 
provide an improved retail shelf inventory management sys- 
25 tern. Other important objects of the pres nt invention are 
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to provide an improved retail shelf inventory management 
system capable of identifying an optimum shelf capacity on 
an individual product basis; to provide such a system capa- 
ble of identifying target stock levels and order-to-levels 
5 separately utilizing the identified optimum shelf capacity 
and/or a user supplied shelf capacity value; and to provide 
such a system capable of identifying estimated sales and 
customer service levels achieved. 

In brief , the objects and advantages of the pre- 
0 sent invention are achieved by a retail shelf inventory 
management system including memory for storing inventory 
data. The inventory data includes a study period and a re- 
tail opening time and a retail closing time for each day 
within the study period and historical inventory data for 
5 the study period for each of a number of different inven- 
tory items or products. The historical inventory data in- 
cludes a movement value , a customer service level, a pro- 
portion of business done for each day within the study pe- 
riod, and a variability of demand. Optimizing means are 
) operatively connected to said memory means for optimizing a 
shelf capacity for any or each of said plurality of in- 
ventory items. Both user selected shelf capacity values 
and the optimized shelf capacity value can be separately 
utilized for calculating target stock levels, order-to- 
> levels, estimated sales, estimated lost sales, average 
inventory values and customer service levels achieved. 

Brief Description of the Drawing 

The present invention together- with the above and 
other objects and advantages may best be understood from 
the following detailed description of the embodiment of the 
invention illustrated in the drawings, wherein: 

FIG. 1 is a block diagram representation of a re- 
tail shelf inventory system according to the present inven- 
tion; and 
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FIGS. 2-7 are flow charts illustrating the logi- 
cal steps performed by the retail shelf inventory system of 
F *G. !• ... 1" 

petailed Description of the PrefeiTfid»^j rT) f - 1 
5 Referring now to the drawings, .in FIG;\l there is 

illustrated a block diagram representation of^isk retail 
shelf inventory system generally designated by the refer- 
ence character 10. . , . ' 

Appendix I below sets f orth a detailed 4eecrip- 

10 tion of a stochastic inventory model according tq the pre- 
sent invention. Appendix I provides a problem definition 
and provides the results by the stochastic inventory jgodel 
of the invention and includes both a mathematical descrip- 
tion and a corresponding exemplary program specification 

15 written in Pascal for implementing the mathematical de- 
scription . 

As illustrated in FIG. 1, the retail shelf inven- 
tory system 10 includes a central processing unit 12 and an 
associated memory generally designated by the:, reference 
20 character 14. As shown, the memory 14 includes; # program 
memory space 16 for storing the retail shelfi inventory pro- 
gram of the invention and a plurality* q£ data, memory Spaces 
18 for storing multiple data files (1)^{Q) -including both 
user supplied data and computed results data of data sets 
25 and arrays. A keyboard 20 is coupled to the central pro- 
cessing unit 12 for entering user selections an* data. A 
display 22 and a printer 24 are also coupled to £he central 
processing unit 12 <*or reporting .calculated results to the 
user. The retail shelf inventory system 10 can bfe imple- 
mented by a personal computer system, for example, such as r 
an IBM PS/2 Model 80 with an associated disk drive ?0fl 
bytes memory, or various other commercially available mi- 
crocomputer based -ystems. * 

As set forth below in Appendix I unde^jheadjng 
35 "B. Results from the model" , the retail shelf £nve»tory 

system 10 provides an optimum shel-f capacity on an individ- 
ual product basis. Optimum stocking times when a shelf 
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should be replenished also can be provided by "the retail 
shelf invent ry system 10. For both the calculated optimum 
shelf capacity and each of the user entered shelf capacity 
values, the inventory system 10 generated results can in- 
5 elude order- to-quanti ties for reordering- estimated lost 

sales and average inventory stock values for both the store 
and shelf stock as seen by a customer. In accordance with 
a feature of the invention, the daily opening and closing 
store times and historical values of the proportions of 

10 business done by day within a study period are supplied by 
the user and utilized for generating the user selected re- 
sults to be reported for a particular product. The use of 
actual opening and closing store times together with the 
proportional business done values simplifies mathematical 

15 calculations and can provide increased accuracy for gener- 
ated results* 

Referring now to FIG. 2, there is shown a flow 
chart generally illustrating the overall program logic se- 
quence in accordance with the principles of the invention 

20 for the shelf inventory system 10. The program starts with 
an INITIALIZATION routine performed indicated at a block 
200 • The INITIALIZATION routine is illustrated and 
described with respect to FIG. 3 and in Appendix I under 
the heading "Solution: Mathematical Description" f 

25 subheadings "1. Notation* 1 and "2. Preliminaries* 1 ; under 

the heading "Solution: Program Specifications," subheadings 
"1. Variables" and v -2. Initialisation." 

Then an optional STOCKING TIME routine indicated 
at a block 202 indicated at a block 204 shown in dotted 

30 line can be performed to provide optimum stocking times 
when a shelf should be replenished. At least an initial 
stocking time is supplied by the user, then subsequent 
optimal stocking times are calculated to space the subse- 
quent stockings evenly in shop time over the study period. 

35 Subsequent optimal stock times are identified by calculat- 
ing an inverse function of clock as defined in Appendix I 
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under the heading "Solution: Mathematical Description," 
subheading "3. Optimal stocking times;" 

Next an optimum SHELF CAPACITY routin in&icated 
at a block 204 is performed for providing an optimum shelf 
5 capacity value. The optimum SHELF CAPACITY routine is 
illustrated and described with respect to FIG. 4 and in 
Appendix I under the heading "Solution* Mathematical 
Description," subheading "4. Calculating optimal. ^shelf 
capacity" and under the heading "Solution: Program 
10 Specifications , H subheading "3. Calculating shelf 
capacity . w 

Next a TARGET STOCK routine indicated at a block 
206 is performed for calculating target stock levels and 
order-to-levels . The TARGET STOCK routine is illustrated 

15 and described with respect to FIG. 5 and in Appendix I 
under the heading "Solution; Mathematical Description," 
subheading "5. Calculating target stock levels, jand order- 
to levels" and under the heading "Solution: Program 
Specifications," subheading "4. Calculating target stock 

20 levels, and order-to levels." 

Next a LOST SALES routine indicated at -a block 
208 is performed for calculating the expected lost sales 
and the customer service level achieved for the study 
period. The LOST SALES routine is illustrated and 

25 described with respect to FIG. 6 and in Appendix I under 
the heading "Solution: Mathematical Description," 
subheading "6. Lost sales" and under the heading > Solution: 
Program Specifications," subheading "5. Lost sale$. n 

Next an AVERAGE INVENTORY routine indiq§tted at a 

30 block 210 is performed for calculating the expected average 
shelf inventory seen by the customer, the expected average 
store inventory at the close of business on a particular 
day within the study period and the expected total' store 
amount. The AVERAGE INVENTORY routine is illustrated ..and 

35 described with respect to FIG. 7 and in Appendix! under 

the heading "Solution: Mathematical Description f » subhead- 
ing w 7. Average inventory calculations" and under the 
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heading "Solution: Program Specifications , " subheading "6. 
Average inventory calculations." 

Referring to FIG. 3, there is shown a flow chart 
illustrating the sequential steps performed during the INI- 
5 TILIZATION routine. The INITILIZATION routine begins with 
the definition of initial and default values for constants, 
variables, and functions utilizing user supplied data 
structure definitions. The user supplied data is set forth 
in Appendix I tinder the heading "A. factors influencing the 

10 model." The user supplied data is included within the list 
of variables used in the program in Appendix I under the 
heading "Solution: Program Specifications, subheading "1. 
Variables 11 as defined under the heading "Solution : 
Mathematical Description " , subheadings tt l. Notation 11 and 

15 "2. Preliminaries." The user supplied data is read and 

copied into the defined data structures, then precalcula- 
tions are performed on the user supplied data on an indi- 
vidual product basis indicated at a block 300. 

As illustrated in Appendix I under the heading 

20 "Solution: Program Specifications, subheading "2. Initial- 
isation," the user supplied time schedule values are con- 
verted from real time into shop time and the proportion of 
total business done and the modified mean demand in each 
interstocking period is calculated indicated at a block 302 

25 and described with reference to FIG. 3 as follows. 

First an order shop time array and a delivery 
shop time array is calculated utilizing the user supplied 
store opening and closing time for each day J=o , . . . , L-l 
in the study period and user supplied order and delivery 

30 real time schedule indicated at a block 304. Next when 
stocking times are user supplied, the user supplied 
stocking times are converted to shop time to generate a 
stocking shop time array indicated at a block 306. Other- 
wise when only an initial stocking time is user supplied, 

35 then the stocking shop time array is calculated indicated 

at the block 306. Next the proportion of business done and 
the modified mean demand during each stocking interval is 
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calculated indicated at a block 308 Error checking 
routines indicated at blocks 310, 312 are sequentially 
performed on the calculated results for each df the above 
described steps. When errors are not detected at the block 
5 310, the results are stored indicated at a block 314 in 
predefined corresponding data structure for results of 
supply, stock and demand data sets. 

* ** 

Referring now to Fig. 4, there is shown a flow 
chart illustrating the logical steps of the SHELF CAPACITY 

10 routine performed for calculating an optimal shelf capac- 
ity. Appendix I under the heading "Solution: Mathematical 
Description" , subheading "4. Calculating optimal shelf ca- 
pacity 11 and tinder the heading "Solution: Program Specif ica- 
tions, subheading "3. Calculating shelf capacity* describes 

15 the SHELF CAPACITY routine in detail. The sequential steps 
begin by identifying one of Methods 1 indicated at a block 
400, Method 2 indicated at a block 402 "or Method 3 
indicated at a block 404 to be utilized for calculajtiAg the 
optimal shelf capacity. A particular Method 1, 2, "or 3 is 

20 performed responsive to a user entered method selection for 
the optimum shelf capacity calculation. Next for_ either of 
the Methods 1, 2, and 3, historical demand inventory kata 
for the particular product, the proportion of business 
done, the modified mean demand during .each interstocking 

25 interval and the desired customer service level is col- 
lected indicated respectively at block 406, 408 or 41p. 

When Method l is selected a root finding routine 
is performed to identify the optimum shelf capacity C. 
This root finding routine evaluates repeatedly the expected 

30 overall lost sales indicated at a block 412 for the entire 
study period utilizing user supplied data,. : thq calculated 
values of proportions of business done and modified mean 
demand for each interstocking periQd, the demand and the 
customer service level to be achieved as set forth in Ap- 

35 pendix I under the subheadings "Method 1." if the root 

finding fails indicated at a block 414, then an e*£or flag 
is set and no value is stored. Otherwise the result from 
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the root finding calculation is stored indicated at a block 
416 as the optimum shelf capacity. 

When Method 2 is utilized for finding the optimum 
shelf capacity C, then an index k is found for which the 

•c jt — - — «-w^«*www s*vnw xn caacs j -~ XllL-«£"»t.OCKJ.ng pSTXOd 

is greatest. Then the optimum shelf capacity is identified 
to achieve the desired customer service level during the 
identified busiest interstocking period indicated at a 
block 418 rather than the entire study period utilized in 
10 Method l. The Method 2 routine is set forth in Appendix I 
under the subheadings "Method 2." When an error indicated 
at a block 420 does hot result from the calculation of the 
optimum shelf capacity of Method 2, then the computed 
optimum shelf value is stored indicated at a block 422. 
15 Method 3 identifies an optimum value for shelf 

capacity utilizing a block of the busiest or worst r con- 
secutive days identified in the entire study period 
indicated at a block 424 as set forth in Appendix I under 
the subheadings "Method 3." The worst r consecutive days 
20 can occur within a single or multiple interstocking 

periods. When an error indicated at a block 426 does not 
result from the calculation of the optimum shelf capacity 
of Method 3, then the computed optimum shelf value is 
stored indicated at a block 428. 
25 When the user has supplied one or more values for 

the shelf capacity indicated at a block 430, for example, 
such as, a current shelf capacity and a selected shelf 
capacity then the user defined C value or values are stored 
indicated at a block 432 for subsequent computations. 

Referring to FIG. 5 f there is shown a flow chart 
illustrating the TARGET STOCK LEVEL routine. The sequen- 
tial steps begin with identifying first a stored shelf 
value C indicated at a block 500. The identified stored 
shelf value C can be either the calculated optimum shelf 
35 value or one supplied by the user. Next the expected sales 
in the j 1 * interstocking period are calculated indicated at 
a block 502 using the formula set forth in Appendix I under 
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the heading "Solution: A Mathematical Description , 
subheading "Method 3." Then an effective deliverable is 
calculated indicated at a block 504 as set forth irT : 
paragraph (5i) in Appendix I under the heading "^plution: 
5 Mathematical Description", subheading "5. CalAjdating 
target stock levels , and order-to levels*- NexsVan 
internal target stock level value is calculated 
indicated at a block 506 using the formula set Xprth under 
paragraph (5). The calculated internal stock leyel is then 

10 stored for subsequent computations. Next an ordsrrto^level 
is calculated indicated at blocks 508 , 510 utilising the 
shelf value C and the stored internal target stock level by 
calculating the expected sales between the order time' and 
the delivery time using the formulas set forth under para- 

15 graphs (5a), (5b). The order- to-level is identified to en- 
sure that the stored internal target stock level value 
is satisfied at the delivery time. 

Referring now to FIG. 6, there is shown, a flow 
chart illustrating the logical steps performed for the LOST 

20 SALES routine. The LOST SALES routine is described in Ap- 
pendix I under the heading "Solution: Mathematical Descrip- 
tion," subheading "6. Lost sales" and under the heading 
"Solution: Program Specifications," subheading .".5* Lost 
sales." The sequential steps begin with a ca^cu^tioh 

25 indicated at a block 600 of the effective stock level that 
is recursively calculated starting from a selected index k 
for which internal calculated target stock level, is maximal 
utilizing the formulas set forth in paragraphs (§), (6a) , 
and (6b). The calculated effective stock levels are then 

30 stored for subsequent computations. Then the expecteci lost 
sales for the whole study period is calculated indicated at 
a block 602 in accordance with the formula set forth in 
paragraph 6(c). Then the customer service level CSL 
achieved is calculated indicated at a block 604 using the 

35 resultant expected lost sales value utilizing the. formula 
set forth in paragraph 6(d). 



I 



WO 90/09638 



-10- 



PCT/US90/606S2 



Referring now to FIG. 7, there is shown a flow 
chart illustrating the sequential steps of the AVERAGE IN- 
VENTORY routine. Appendix I under the heading "Solution: 
Mathematical Description", subheading "7. Average inventory 
5 calculations" and under the heading "Solution? Program 

Specifications, subheading "6. Average inventory calcula- 
tions" describes the AVERAGE INVENTORY routine in detail. 
The sequential steps begin with calculations indicated at a 
block 700 of the expected amount of backroom stock b and 

10 shelf stock a just after the j* 11 stocking time, utilizing a 
computed expected sales value utilizing the formulas of 
paragraphs 7(a) and 7(b) . Next the functions a(t) and b(t) 
are interpolated indicated at a block 702 between the 
calculated a, b values to identify average stock amount on 

15 the shelf and in the backroom in accordance with the 
formulas of paragraphs 7(c) and 7(d). Next numerical 
integration of the a(t) time value is calculated indicated 
at a block 704 as set forth under paragraph (i) "Average 
Amounts Seen by the Customer." Next the average store 

20 inventory is calculated indicated at a block 706 utilizing 
store time as set forth under paragraph (ii). Then a 
numerical integration routine can be performed indicated at 
a block 708 to provide a real time average store inventory 
as set forth under paragraph (iii). 

25 Then the sequential functions or selected func- 

tions of the TARGET STOCK LEVEL, LOST SALES and AVERAGE IN- 
VENTORY routines are repeated for the next stored shelf c 
pacity value C. 
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APPENDIX I 
STOCHASTIC INVENTORY MODEL x 

Problem Definition ' " ' 

To derive* on an individual product basis, a stochastic inventory model wring the fac* 
tors, given below, influencing sales and bencc the stock level and rc-oider st$u%ics. 

A. Factors influencing the model 

1. The study period; variable from 1 day to a year. 

2. The daily opening times; for each day in the study period, the opening and closing 
times of the store are stated. 

3. The demand cycle; this is derived from the following historical data: 
(i) n^vement figure over the period 

GO customer service level over the period • 

Cm) distribution of business by day (I.e. sales percentages by day) 

(iv) variability of demand over the period " 

4. The number of times the shelf is replenished during the study period. 

5. The stocking schedule; each time and day within the study period when, the shelf is 
replenished is stated. 

6. The number of deliveries to the store during the study period. 

7. The order and delivery schedule; each time and day when an order is raised, Le. the 
time at which the amount to be re-onicred is calculated, together with its associated 
time and day of delivery within the study period. 

8. The target stock levels; the total amount of stock in the store after egch delivery. 

9. The actual shelf capacity , v he amount of the product currently displayed on the shelf. 

10. The desired customer service level. 
[User definition of factors 
Obligatory 

AltoA4 

First stocking time in A5 
A6toA7,A10. 

Optional 

Rest of stocking schedule in A5 
A8 and A9. 

(If A3 and A8 art not fully defined by the user, then the optimal values are produced and 
used by the model.) ] 
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B. Results flrom the model 

1. Optimal stocking times, the times and days during the Study period when the shelf 
should be replenished. 

[Only used if A5 not fully defined by the user.] 

2* Optimal shelf capacity; the amount of the product which should be displayed on 6c 
shelf to meet the factors Al to A5. 

3. For each of the shelf capacities (Le. both Actual and Optimal) the following results 
may be derived: 

(i) Re-ordcr schedule; for each order point a stock level which the store must re- 
order to (hence any stock in the store and any stock currently on order must be 
taken into account when calculating the amount to re*oider)» 

(ii) Lost sales; the sales not achieved by accepting this shelf sue and accounting for 
the backroom* 

(Hi) Average inventory; the average amount of stock in the store. 

(iv) Average amount on shelf, the average amount of stock on the shelf as seen by 
the customer. 

4. Actual customer service level; the customer service level actually achieved when 
using the actual shelf capacity (A9) rather than the optimal shelf capacity (B2X 
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Solutkm: Mathematical Description 



UVUIUVil 




z, 


length of study period (in days) 




time of opening on day J J = 0, L-t 




time of closing on day /, j « 0, L-l 


n' 


historical movement figure for the study period 


ioop% 


desired customer service level 


100c% 


historical customer service level 




proportion of business done oh day 7 


I00v% 


variability of demand 




number of stockings of shelf 


T* 


time of** stocking of shelf, Jk =0, N-l 


Af 


number of deliveries 




time of J* delivery, / = 0, .... M -I 




time of y* order J =0 M-l 




/* target stock level, j=0, .... Af-1 




actual shelf capacity 



2. Preliminaries 

CO We input the historical movement figure \i' and the historical customer service 
level a, but what realty matters is the demand, |A» which is the number of times someone 
wants to buy one of the product during the study period. Of course, sometimes a custo- 
mer who wants the product will find the shelf empty and be unable to get the item, but this 
will only happen in a proportion (1 - a) of cases. Otherwise, the customer will take the 
item from the shelf, and the movement figure goes up by one. Hence 

\i a movement = demand x historical customer service fcfevel 
so demand [i = h'/ol 

(ii) If the variability of demand is v, the standard deviation wiH"be jiv, and so the 
variance of demand, o 2 , will be Qiv) 2 . 

(iii) To calculate the proportions of business done in each interstockitig period, we 
maJee use of the function clock: [OX] -» [0,1], which is defined as 

clock(r) m proportion of total business done by lime r 
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Wc subsequently extend clock periodically to the whole of the real line, so that 
ciock(nL + 0 * it + cIock(r) 

for integers «, and r in [0,L]. The purpose of clock is to convert the real time / into the 
shop time clock(t). As far as the shop is concerned, it is shop time which marten; busi- 
ness proceeds at a constant rate in shop time. 

(xv) We also assume that the study period repeats itself, so that if (T 0? Tjl is the 
zero* intersiocking period, the (AM) A is (7> _j t L + T Q ] % for example. The proportion of 
business done in the j * interlocking period is simply 

Pj * ciockCT ;+ i) - cIock(Ty) , 

where T N » L + Tq. 

(v) We model the demand in the ;* interlocking period by the random variable 
Yj, which is the positive pan of a normal random variable Xj* whose variance is pjO 1 and 
whose mean \ij is chosen so that the expected value of Yj y Ely, is equal to the mean 
demand in the period, ppj. More explicitly, if we define the function A by 

0) Atz) « ^^^^(2). 

where m P(Z >x)forZi//(DJ) random variable, then 

(2) Mz) = 

thus we choose \ij to solve 

(3) m . a^^-j. 

INotc; The choice of a normal distribution for Z is essentially arbitrary, and any rero- 
mean unit-variance distribution could serve instead. The expression (2) for A stays the 
same, bur the explicit formula (1) will change] 

3. Optimal stocking times 

Suppose we have been told the time To o f zero* sxocking, which occurs at the 
shop time to *clock(To). Then thebest way to choose subsequent stocking times is to 
space them out evenly through the study period - but 'evenly' in terms of shop rime. Thus 
we define 
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a To + JM, /" l ^-1, 

(with addition mod t) and set the recommended stocking times T\> .-.J*n-\ to be 
Tj m clockinv(tp , 

where clockinv is the inverse function to clock; clocking) = inf{u: clock (u)> i). this 
function can be expressed explicitly in terms of the Bp sptj and L veiy'intiCh as <fcck 
can. Less satisfactorily, it can be evaluated by a general root-finding routing f$&j$lock. 

The user can, of course, ignore the recommended Tj and supply his own; : - • 

4, Calculating optimal shelf capacity - 

If the shelf capacity is C, then assuming that the shelf it fiifl at die beginning of the 
j 0 * interstocking period, the expected lost sales in they* imemocking period is given by 
the formula ' * 



(4) \j(C) m arlpjA 



which is £(Tj-C)\ ' 7 

There are now three possible ways of choosing the optimal shelf capacity, cfepepding 
on the user's performance criteria. We consider the first to be the roost natural As usual, 
the user is free to ignore the recommended shelf capacity, and input his own value C* 
instead. 

Method L This method should be used if the aim is to ensure that on average 10QJJ% of 
the total demand throughout the study period will be met. Assuming that there is always 
enough available at the start of an interstocking period to fill thd"Shclf f \he expected test 
sales in the study period is ' * * 

/(C) =* j\(C) \ 

when the shelf capacity is C and we simply pick C so that 



/(C) - • 
This will need a root-finding routine. 
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Metbod 2* This method will ensure that during each interlocking period, at least 
1000% of the demand will be met Find the index k for which pj is greatest, and then 



**(C) (l-p)W>* . 
This choice of C will always be higher than in Method 1, 

Method 3. This method should be used if the aim is to have the shelf large enough to 
cany through the worst r consecutive days in die study period. To do this, let p be the 
maximum of e ; - + + e^,^ asy varies, calculate v as in (3): 



lip = trip A 



and now choose C as in Method 2: 

f \ 



At this stage, the program has a value of C to work with, either computed by one of 
the three methods, or else input by the user. Now one can compute, for example, the 
expected sales in the /* interstocking period: 

Sj = Sj(C) « £07 aC) - VP} - X/(C) . 

5> Calculating target stock levels, and order-to levels 

The user inputs the number M of deliveries in the study period, the times 
&o* ~ JPjf-i at which they are made, and the times Oo, «..Oj/.i at which the correspond- 
ing orders arc placed. Some retailers may require to be protected against delays in 
delivery of up to 5, in which case we replace D) by Z>J + 5, and since we cannot make use 
of delivered goods until the next stocking after delivery, we immediately replace D' } by 
the effective delivery time 

<5i) Dj = inf (7* : T k >0'j) - 

Now if D k =T rt D k +i= T^+i (n > 0), our target stock level W t at the delivery 
time D k will be set so as to meet on average the sales to be made in (7,J> 
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(5) 



«) 



v C 



We take the maximum with C so as to ensure that we Stan with & full shelf at The 
objective is to ensure that just after the delivery has beenfaade, the tcfef amount in the 
shop (shelf + backroom) is W k (or more). Thus we choose the order jo level V k to 
achieve this* as follows. 

Firstly we calculate (an upper bound for) the expected sales in (9*0*1, ty summing 
the expected sales 5, for each interstocking interval j contained entirely in {O^Dkl and 
then adding a correction for the sales between 0* and the next stocking tnj*. Expliculy, 
if O* occurs in interstocking period m, shop time t after the beginning of the interstocking 
period, then ihe expected sales between O* and the end of interstocking period m is 



5(a) S t 



- s m - 



Pm 



this is the correction we add in, to arrive at the expected sales U k dflring {O k ,D k \ We 
now define rhe k * order-to level by 

5(b) V* - Wik + V k . ' 

The interpretation is this. At time 0*, we have amount x in the shop (shelf + backroom) 
and we have placed orders for a total amount y which has not yet been delivered; we 
therefore place an order for amount (V*-x -v)\ 



6. Lost sales 

We have chosen a shelf capacity C, and target stock levels W 0p „.,Wm-\. Suppose 
that D k a 7, , D* ♦! = T r +n ^ . Then the lost sales in {D k .D k ¥} ] is exactly 



r ♦ n 



^ A lV/AC)l 



The expected value of this is too cumbersome to evaluate explicitly, so we approximate 
the expected lost sales in (D k *D k +i) by * 



r + n 



(6) AtiC.W k ) = n 2 Pi - 



Wc could now just sum the A k (C,W k ) to yield expected lost sales, but this would be 
erroneous for the following reason. Suppose that W } , ^ f Wjn^ were aQ very small, but 
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Wq was enoimous. Then there would be lots of unsold stock at time P \, so effectively 
there would be more in the shop at timcDi than W u What we need to do is replace the 
target stock levels W k by the effective target stock levels and then proceed. 

We calculate the effective target stock levels W k as follows. Pick the index k for 
which W k is maximal; suppose for convenience thai it is Jfc * 0* Then wc set 

and define recursively 

6(b) w M « W ux v [Wt - nCclockCO^O-cIockCDi)) + A,<C,Wi)) . 

This is because if we had Wi in the shop at D h the demand in (PiJ>i+t) would be 
HfclockCD,^) - clock(£>,)h of which on average Aj(C»Wj) would be lost The amount 
remaining just before Di+i would be Wi-\iicUxk(Pi+i)-clock(Pi)} + A^C.WiX and 
this might exceed W^j. 

Finally, then, we calculate the expected lost sales for the whole study period: 

M-l 

S (c) Expected lost sales = £ MGHW . 
From this follows the customer service level achieved: 
6(d) 100 [1 - (Expected lost saksV)i]% - 

7. Average inventory calculations 

The first step here is to calculate the expected amount on the shelf and in the t ;ck- 
room just before and just after the locking time, Tj* 

Suppose that just after Tj> there is aj on the shelf and bj in the backroom. Just before 
Tj+i, there is b $ in the backroom and (approximately) (fly -S ; ) v * faj - a C))* on 
the Shelf Thus 

7(a) bj*i = (6/ - CS/Atfj))* 

except when Tj is a delivery time D*, in whicvh case bj + tf/ is simply the effective target 
stock level W k9 and a ; * is just W k a C. 

The second stage is to interpolate between these values to obtain functions a (•). b (•) 
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far the average amo«n? on lh£ shelf and in the backroom^ The. b»ckxO0!2 *?OCk level is 

easy: 

7(c) 6(0 * bj (Xj £ t < tj+ x ) • 

For the amount on the shelf, we set * 

[Recall that ty «clock(Ty).] Fiom this, we can obtain the average amount on the shelf (or 
in the backroom), however one may choose to define it Vfe suggest some possibilities 
here. 

(i) Average amount seen by the customer. This is simply 

[ l a(t)dt 9 

which can be evaluated by a (trapezium rule) numerical integration, 

(ii) Average amount in the store at the end of the day's trading. This amount in the 
shop at the close of trading on day j is simply 

Pj m a(clock(f,.)) + Mclock(r ; )) t 



so the average amount at the end of the day's business is just 



IP; 



(Hi) Average amount in store. (This is the 'true' average, averaged in real time.) 
This is calculated simnlv as ' "' 

£-{a(clock(s)) + b(clock{s))]dslL , 
again a candidate for the numerical integration routine. 
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That follows a largely complete Pascal program id carry out the calculations laid out in 
the mathematical description. 

1. Variables 

type 

vec * array [0..MAX] of real; 
daily « array [0.365] of real; 
vec_int * array [0..MAX] of integer; 

{the parameter MAX should be set large enough to cope with the biggest value of ostock, 
the number of stockings. MAX a 700 will probably do. J 



{There follows a list of the variables used in the program, together with their type, range 
of possible values, and symbol used in the mathematical description Of applicable). It is 
assumed that all the variables above the line have already been input} 



Variable name 


type 


range 


math* symbol 


nday 


integer 


1^.365 


L 


opentimcs 


daily 


array of increasing reals in [0.11 




dosetimes 


daily 


array of increasing reals in [0,1] 


«/> 


hist_roovement 


real 


positive integer 


V? 


CSL 


real 


(0,1) 




hist.CSL 


real 


(0.1) 


a 


proportions 


daily 


reals in [0,1] 


ce,) 


variability 


real 


positive real 


V 


nstock 


integer 


C..,MAX 


N 


stock_true_timc (1 x (1) 


vec 


reals in [0,1] 




ndel 


integer 




M 


deLtrue_iimc (1) 


vec 


reals in [0,1] 


0>1) 


order.true - ttme (l) 


vec 


reals in [0,1] 




delay_protect 


real 


[0,1] 


5 


CO) 


real 


positive real 




target_$tock_lcvcls (4) 


positive reals 
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demand 


real 




it 




rca* 






stoc )c_$nop__ume 


vcc 


r*^ie jit rn 11 




flat Tl J li l |«im* 

aei_snop_jime 


vcc 


rca 15 in Lv>* j 




order_$hop_time 


vcc 


reals in IU,1 J 




P 


vcc 


rca is in ivM J 




njOu^ocuianos 


vcc 




fit A 


sales 


vcc 


pOSluVC ZvoIS 




raw_csl 


VCC 


positive icais 




4«M>J| HJU>1» Ia«>aT» 

UkrgCI^.5COCiUCVCl5 


VCC 


posiuvc reals 




effectivejtd 


VCC 


positive reals 




shelf 


VCC 


positive reals 


(a,) 


backroom 


vcc 


positive reals 


($/) 


order_to 


VCC 


positive reals 


' (V*) 


vtr 


real 


positive real 




b 


real 


positive real 




flag 


vecjnt 


-1,(W>MAX-1 




iead_time_salcs 


vcc 


positive real 




lost_$ales 


real 


positive real 




CSL_achieved 


real 


real in [0,1] 





{l) The entries stock.true^umetQ],..., $tock_mie_time [nstock-l] are the succes- 
sive times at which stockings are made. All subsequent entries in the array are Ini- 
tialised to 0. Similarly for deLtruejime, order.true.time. 
°* The program contains a facility for calculating the arr^y stock_twejitnc from 
the input value stoek_true_time[0| alone; so in some uses, tt would be satisfactory 
to input only this one value. 

< J) There may be no value of C offered, because the main program has the capaci- 
ty to calculate C 

(4) Hjc user may wish to input the target stock levels (one for each of the fidel 
deliveries), but the program will calculate these if they are riot input 
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2. Initialisation 
begin 

cpsilon :» 1.0E-6 

demand := hist_movcment/hist_C$L; 
sigma dcraand*variability; 
var :» sigma^sigma; 
h 1.0/hstock; 

stock_tnie_rime [nstock] stockjn*_timc[01; 
dcLtruc.timetndcl] dd.tnie.iimep]; 
order jrue_dme [odd] ^ order_true_timc[0]; 
{These conventions make 'wrap round 1 easier.} 
for j r-0 tondel do 
begin 

dcL*op_timcQ| :- clock(del^true^timcO] f opentimes, closctiroes, 

proportions, nday); 
order_shop_tirncBJ :- clock (order^tnie^tone[j]» opemimes, closelimes 

proportions, nday); 

end; 

{It may be that the user has input only stock_truc_timelO], and is leaving it to the program 
to calculate the rest of the array. This is done as follows: 

stock.shopjirocIO] := cloc*(suxk_tnic jimeLO], opemimes, closetimes, 

proportions* nday); 

for j 1 to nstock do 
begin 

stock^shop_time[jl :* plu5(stock.shop_timelj-l]^); 
stock_tnie_time|jl clockinv(stock.shop_time(jl, openrimes, 

closetimes, proportions, nday); 

end; 

We assume therefore that the arrays stock_true_time and stock^shop.time have been ini- 
tialised*} 



for j :*0 to nstock- 1 do 
begin 

pOl pius(stock_shop_time|j+IL -stock_shop.dme{jl); 
mod^demands[jl t» rnodmcin(pfjl, rigma. demand) 
end; 
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Maln Routines 

3. Calculating shelf capacity 

{Firstly, note that if the shelf capacity is C, then the expected lost sales for the whole 
study period (assuming no backroom interference) is given by the function 

toUo$s(Greal;sigraa:rea]; n$tock:integer; p:vcc; mod^demands:vec)^eaL 

There are three methods available. ^ 
Mttkodl 

Use a root-finding routine to pick C so that 
tot.loss(C^.) m demand*(l-CSL). 

Method 2 

fnnd which of p[0)„„j>[n$tock-l] is greatest (p[r], say) and then choose C so that 
k)$$((^gma,p[r], mod_demands[rD » dcxnand*p[r]*(l-CSL). 

• *■ >• 

Methods 

This is used when a retailer requires to be covered against the busiest consecutive K days 
trading ? 

readCK); 

fori ;=0 tonday-1 do 
begin 

y :-0.0; 

fork:-0toK-ldo 

begin 

I := (i+k) mod nday; 
y := y + proportions [1] 

end; 
if(y>x)then 

x:-y; 

end; 

z := modmean (x, si g ma, demand); 
{and now we use the root-finding routine to pick C so that 



WO 90/09638 



-24- 



PCT/IK90/00652 



100(0, Sigma, x, z) » demand* x * (1-CSL). } 

(By now, the program has a value of C to work with, either calculated by one of the above 
methods, or input by the user. Now we can compute the expected sales in each interlock- 
ing period:} 

for j := 0 to nstock-1 do 

salesQ] > dcmand*p[jl - loss(Q sigma, p(j), mod^demandspl); 

4. Calculating target stock levels, and order-to levels 

for j:=Otondcldo 
begin 

deLtnie_time[fl plus(deLtnie_time[jJ, delayjwotect -epsilon); 
deLshop_rime[j] :» clock(dcLmje_time[fl, opemimes, ctosetimes, 

proportions, nday) 

end; 

{next, we work out the effective delivery times, and store these in dd_truc_timc, 
dcLshop.time.} 

fdri:=OtoMAXdo 
flagli]:--l; 

fbrk:*0toDdel-t do 
begin 

fbrj^Otonstock-ldo 
begin 

1 Q+l) mod nstock; 

if contain(deLtrue.time[k] t stock.true.timelj], stock_true-time[l)) then 
begin 

deLirue_time[k] plus(siock_true_ume[l], -epsilon); 
del_shop_timeIk] :» pius(stock_shop_timeLl] f -epsilon); 
flagfl] :»k 

end; 

end; 

end; 

deljshop_time[ndel] :* deLshop.tirnelOJ; 
(now we get the order times into shop time) 
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forkr-Otondeldo . ■ 

orier_shcp_time(k] :» plus(clock(onier_mie_tirofe[kl, opentimes, doseSmeSt 

proportions, relay), -2* epsOoh); 

{Now the calculation of target stock levels: } 

forj:«Otondcl-ldo 
begin 

raw_tsl[j] 0.0; 

for i ^ 0 to nstock-l do 

begin 

if contain(stock_shop.tupe[i] t dcl_sbqp_timeG]. <H^hop-£ineG+i]) 
then 

caw^tsim raw_tsl{j] + salesfi]; 

end; 

target_stock_levcIs[jJ > max(raw_tsl|j] t C); 

{this assignment statement must be skipped if the user has chosen to input bis own 
targetjrtockjevels) 

end; 

{Now the calculation of lead-time sales:} 

fork :»0 tondeMdo 
bcgin{l} 

x:=0.0; 

for j := 0 to nstock-1 do 
begin[2} 

if conttm(stock_$hop_time(j], order^hop.time[k] t deLshop_time[k]) 
then 

x:»x + $aksfjl; 

else 

if 

contain(order_shop_timelkl4tock_sh^ 
then 

begin{3) 
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t ;= plusCordcr^shop^timepcl, -stock^shopjimeti]); 

z :» i*(demand - (z/pDD); 
2r=sales[j] -£ 
x :» x+z; 
cnd;(3) 
cn*{2} 

lead_time_salcs[k] :=x; 
end;(l} 

{ ft may be thai the user has input target slock levels, rather than relying on the values cal- 
culated by the program. Either way, there is an array target^stockjevels containing this 
data.] 

for k := 0 to ndeJ-1 do 

onJer_to[k] :» lead_time_sales[k] + targeotockjevclsfkl; 

5, Lost sates 

(RreUy, calculate effcctive_t$L} 

x:=0.0; 
kr-O; 

&rj:«0 to ndel-1 do 
begin 

if (targct_stockjcvel$01 > x) then 
be tin 
k:»j; 

x :* target_stock_levels|j] 

end; 

end; 

effectivcjsl[kl target_stockJcvcls[kl; 

fori 1 to ndel-1 do 

begin 

j ;= (k+i-l)mod ndel; 
1 := (k+i) mod ndcl; 

x effectivc_ttl[j] -cnin<raw_tsl[jl t effectivejsHj]); 
effectivejsip] max(x, targeLstockJevelsPJ) 

end; 
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{From this, we calculate next the overall lost sales, and the customer service level 
achieved) 

fork:-OtondeH do 

x :* min(raw_tsl[k] % effcctivc.tsltk]) + x; 
lost_sales :» demand - x; 
CSL.achievcd r= x/demand; 

6. Average inventory calculations 

fork :»0to ndel-I do 

begin 

forj :»0ton$tock-l do 
begin 

> 

iftfagOJ-iOtben 

backroomlj J max(effective_tsl[kM!, 0,0); 
shelfQ] :»min(Ceffective w jsIM) 

end; 

end; 

end; « 
{this has set the values of backroom and sbelf at stocking times when there is a delivery. 
The next task b to calculate h for all stocking times, for which wc most $nd the first 
stocking time which has a delivery, and work from there.} 

i:=0; 

while (flag[i1»-l) do 

i:-i+l; 
forj:=l tonstock-ldo 
begin 

k := 0+j- 1 ) mod nstock; 
1 := (i+j) mod nstock; 
if (flag[l]*-i)thcn 
begin 

x ;» min($helf[kl, sales[k]); 
y:-shcUTk]-x; 

backroomP] tm max(backxoom[kj - x f 0.0); 
shejfllj min(backroom£k] + y, O; 
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cod; 

(The functions a and b allow us to obtain for any t in [0,1] the average amount on the 
shelf (respectively, in the backroom) at time l 

To calculate the average amount seen by the customers, we do a (trapczium-rule) calcula- 
tion of ^aitydt. 

To calculate the average amount in the store at the end of the day's business, we take 

for j 0 to nday-1 do 

gfjj a(clockfj/nday)) + Mclockfj/nday)); 

average := 0.O, 

for j to nday-1 do 

average — average + gG1; 
average — average/nday, 
To find the genuine time-average, we make the integral 



£ (a(clock(t)) + b(clock(t)))dt. } 



WO 90/09638 



-29 



PCT/US9W00fc2 



Subprogram Specifications 

function ctock(u real; a: daily; b: daily; pn daily; n; integer): real; 

{given a time t in the interval (0,1), this function calculates die propoMonfcf business 
done by time L It also extends periodically to the whole line.) 

var 

mj : integer, 
sum, y : real; 

begin 

m := trunc(t); 
x:»t-m; 

if (x >= b[n-l]) then 
clock :* 1.0 

else 
begin 

j>0; 

sum:- 0.0; 

while (x>«bO]) do 

begin 

$um :» sum + pr[j]; 

end; 

y max(0 A (x - atjlVCbljl *&])); 
clock sum + prfjl*min(1.0,y) 

end; 

clock := clock + ra; 

end; 

We also need 

function max(x: real; y: real): real 
which returns the larger of x and y, 

function min(x: real; y; real): real 
which returns the smaller of x and y» and 
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funCuOti uBC(*: ttdl)i real 

which returns x - trunc(x) f the fractional part of x. 

function phis(x: real; y: real): real; 
{this adds x toy modi] 
begin 

plus &ac(x+y) 

end; 

function clockinv(t: real; a; daily; b: daily; pn daily; n: integer): real; 

(this is the inverse function to clock; given U it returns s such that dock(s) * t The array 
t contains opening times, b contains closing times, and pr contains proportions of busi- 
ness done on the various days} 

var 

mj: integer; 
x, sum: real; 
begin 

m ;» trunc(t); 

x:»t<m; 

j^-0; 

sum 0.0; 

while (x>» sum) do 

begin 

sum :» $um + pr{j]; 
j:=j+l 

end; 
z sum -x; 

clockinv :» m + bD] - (b[j] « a[j])*z/pr[)3; 

end; 

function N(z: real): real; 

{this gives a good approximation to the integral from z to infinity of the standard normal 
distribution.) 
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var . 

x,y,v: ret!; 
begin 

y :- 1/(1 + <X23164l90*abs(z)); 

x 0.3989423*exp(-a5»x*z); 

v:- U30274*yVy*y*y; 
v :» v * L821256*y*y*y*y; 

v > v ♦ U8t478*y*y*y; 
v:-v- 0356338 V« 
v*v + 03193875*y; 
v:»x*v; 
if (z>« 0.0) then 



N:«v 

else 
end; 

function A(z: real): teal 

{this gives the expectation of the positive pan of Y-x» where Y is a standard normal ran- 
dom variable) ' ' T 



A ^ 0.3989423*exp(-QJ*i*2) - x*Nfr) 
end; r: v 

function modmean(x: Teal; s: real; d: real): real; 

(if x is the proportion of the business done in some interstocking interval, s is the Standard 
deviation of the overall demand, and d is the overall mean demand, this function works 
out the mean of a normal random variable Y so tba r the expected value of Y* is equal to 
xd.} ; 
Once again a general root-finding routing is needed. This function should return that 
value y such that 



The value y will always be less than xd; negative values are possible, 
function loss(C: real; sigma: real; x: real; mean: teal): real; 



begin 
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[this calculates expected lest sales in our interstocking interval when the shelf capacity U 

C 2nd a proportion x of the business for whole study period is done} 

var 

z;ieal; 
begin 

z:» sigma*sqrt(x); 
loss :» z*A((C-n*any*) 

end; 

function toUos$(C real; sigma: real; nstoclc integer; pevee; nxxLracan: vec): real; 
var 

j: integer, 
begin 

toUoss = 0.0; 

for j 0 to nstock-1 do 

totjoss tm totjow + lossCQ sigma, pOlt mod^roeanQl) 

end; 

function contain(x: real; s: real; b: real): boolean; 

{this function should only be used on arguments in the interval [0,1]; it returns 'trot* if x 
is in the interval from i to b (with the endpoints of the interval wrapped around) other- 
wise *false\) 
begin 

if(a<b)then 

if (a <« x ) and (x <« b) then 

contain := true 
else contain :~ false; 

else 

if (a <= x) or (x <= b) then 

contain :» true 
else contain false 

end; 

function a(u real; stock_shopjime: vec, shelf: vec; sales: vec; demand: real): real; 
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{this works out the average amount on the shelf at time t) 
vtr 

t 

j: integer, 
begin 

for j :« 0 to nstock-1 do 
begin 

If contain^ stock_shop_timc(jK stock_sbop_timeU+l]) then 

§ ^ max(shelf[j) - demand* (t-stock.shopjdmeQt), nrnCshelffthsalcsQ], 
0.0)) 

cod; 

end; 

* 

function b(k teak sux£_shop__time: vec; backroom: vec)t ieaU 
{this works out the average amount in the backroom at time t) 
var 

j: integer; 

begin , 

for j := 0 to nstock-1 do 
begin 

if contain^ stod^jbopjimcOJ, $tockjbcv- tin *D + U) *ea 
b :» backroom^] 

end; 

end; 
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While the invention has been described with ref- % 
erence to d tails of the illustrated embodiment, these de- 
tails are not intended to limit the scope of the invention 
as defined in the appended claims* 



Claims, 

1 1. A retail shelf inventory management §ystem 

2 comprising: 

. .i. . 

3 memory means for storing inventory. dat£, said in- 

4 ventory data including a study period and a retail on^ninci 

5 time and a retail closing time for each day within said 

6 study period and historical inventory data, f ov sai£ study 

7 period for each of a plurality of inventory items including 

8 a movement value, a customer service level, a proportion of 

9 business done for each day within said study period, and a 

10 variability of demand; and 

11 optimizing means opera tively connect^. to said 

12 memory means for optimizing a shelf capacity for each of 

13 said plurality of inventory items. 

»■ * 

1 2. A retail shelf inventory managem^pt system 

2 as recited in claim 1 wherein said, optimizing me^is include 

3 means for calculating an expected lost sales value for said 

4 study period and identifying said shelf capacity resppnsive 

5 to said calculated expected lost sales value. 

1 ■ 3. A retail shelf inventory management system 

2 as recited in claim 1 wherein said inv^tory data includes 

3 a desired customer service level value to be achieved; and 

4 wherein said optimizing means include means fpp calculating 

5 an expected lost sales value for said study period and 

6 identifying said shelf capacity responsive to sai,d calcu- 

7 lated expected _ost sales value and said desired customer 

8 service level value. 
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1 4. A retail shelf inventory management system 

2 as recited in claim 1 wherein said inventory data includes 

3 stocking time values and wherein said optimizing means 

4 include means for identifying an interstocking period 

5 having a maximum proportional value of business done and 

6 . identifying said shelf capacity responsive to said 

7 identified interstocking period. 

1 5. A retail shelf inventory management system 

2 as recited in claim 1 wherein said inventory data includes 

3 a desired customer service level value to be achieved and 

4 said historical inventory data includes interstocking time 

5 values and wherein said optimizing means include means for 

6 identifying an interstocking period having a maximum pro- 

7 portional value of business done and identifying said shelf 

8 capacity responsive to said identified interstocking period 

9 and said desired customer service level value* 

1 6. A retail shelf inventory management system 

2 as recited in claim 1 wherein said inventory data includes 

3 a desired customer service level value to be achieved; and 

4 wherein said optimizing means include means for identifying 

5 a predetermined number of consecutive days having a maximum 

6 proportional value of business done and identifying said 

7 shelf capacity responsive to said identified consecutive 

8 days and said desired customer service level value • 
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1 7. A retail shelf inventory management system 

2 as recited in claim 1 wherein said inventory data' includes 

3 a number of shelf stockings and at least a first stocking 

4 time; and further comprising means for calculating an ' 

5 optimum shelf stocking schedule for said study "period. 

1 8. A retail shelf inventory management system 

2 as recited in claim 1 wherein said historical inventory 

3 data includes a number of order deliveries and delivery 

4 times in said study period for each of said plurality "of 

5 inventory items and further comprising means for c^Ict&at- 

6 xng an effective delivery time and means for calculating a 

7 target stock level responsive to said calculated' Effective 

8 delivery time and said shelf capacity f6r any of said 

9 inventory items. V*. f 

1 9- A retail shelf inventory management system 

2 as recited in claim 1 further comprising means f osr calcii- 

3 lating an order to level defining an order quantity amount 

4 for any of said inventory items. 

1 10. A retail shelf inventory management system 

2 as recited in claim 1 further comprising means for calcii- 

3 lating an expected lost sales value responsive to a user 

4 selected shelf capacity. 

1 11. A retail shelf inventory management system 

2 as recited in claim 1 further comprising means for calcu- 

3 lating an expected lost sales value responsive to said op- 

4 timized shelf capacity. 
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1 12. A retail shelf inventory management system 

2 as recited in claim 1 further comprising means for calcu- 

3 lating an average shelf inventory value responsive to said 

4 optimized shelf capacity. 

1 13 ♦ A retail shelf inventory management system 

2 as recited in claim 1 further comprising means for calcu- 

3 lating an average store inventory value responsive to said 

4 optimized shelf capacity. 

1 14. A retail shelf inventory management system 

2 as recited in claim 1 further comprising means for calcu- 

3 lating an average shelf inventory value and an average 

4 store inventory value responsive to a user selected shelf 

5 capacity. 

1 15. A retail shelf inventory management system 

2 as recited in claim l further comprising input means cou- 

3 pled to said memory means for receiving user input selec- 

4 tions. 



1 16. A retail shelf inventory management system 

2 as recited in claim 1 further comprising display means cou- 

3 pled to said optimizing means for displaying results for a 

4 user of the system. 
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1 17. A retail shelf inventory management system 

2 comprising: 

3 memory means for storing inventory data, said in- 

4 ventory data including a study period .and a retail opening 

5 time and a retail closing time for each day within said 

6 . study period and historical inventory data for said study 

7 period for each of a plurality of inventory iteais Including 

8 a movement value, a customer service level, a prtfpbrtion of 

9 business done for each day within said study pteriod, and a 
10 variability of demand, a number of deliveries and order de- 
ll livery times within said study period and a number of 

12 stockings and stocking times within said study period, and 

13 a customer service level to be achieved; 

14 optimizing means operatively connected to said 

15 memory means for optimizing a shelf capacity for any of 

16 said plurality of inventory items; and 

17 means coupled to said optimizing means fpr calcu- 

18 lating an effective delivery time and an order quantity 

19 amount for any of said inventory items responsive to said 

20 optimized shelf capacity. 

1 18. A retail shelf inventory management system 

2 as recited in claim 17 wherein said optimizing means in- 

3 elude means for calculating an expected lost sales value 

4 for said study period and identifying said shelf capacity 

5 responsive to said calculated expected lost sales value. 

1 19. A retail shelf inventory management system 

2 as recited in claim 17 wherein said inventory data includes 

3 a desired customer service level value to be achieved; :and 

4 wherein said optimizing means include means fof calculating 

5 an expected lost sales value for said study period and 

6 identifying said shelf capacity responsive to said caicu- 

7 lated expected lost sales value and said desired customer 

8 service level value. 
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1 20. A retail shelf inv ntory management system 

2 as recited in claim 17 wherein said inventory data includes 

3 a desired customer service level value to be achieved and 

4 said historical inventory data includes iriterstocking time 

5 values and wherein said optimizing means include means for 

6 • identifying an interstocking period having a maximum pro- 

7 portional value of business done and identifying said shelf 

8 capacity responsive to said identified interstocking period 

9 and said desired customer service level value. 
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